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Related Application 

Related subject matter is disclosed in United States patent application number 
09/XXX,XXX filed XXXXX XX, 2000, assigned to the same assignee, having an attorney 
docket number of 1 15 146, and hereby incorporated by reference. 

Field of the Invention 

This invention relates, in general, to data transmission, and more particularly, to methods 
of determine time delay for a round-trip transmission of data and apparatuses therefor. 

Background of the Invention 
A user accessing a computer server across a computer network must transmit data across 
the computer network from the user's computer to the computer server and must also receive 
data across the computer network from the computer server to the user's computer. Therefore, 
the user requires fast data transmission rates across the computer network and requires, in 
particular, fast round-trip data transmission across the computer network. However, as computer 
networks continuously grow in size and complexity, the data transmission rates associated with 
the larger and more complex computer networks may decrease. Accordingly, a need exists for a 
method of determining a time delay for the round-trip transmission of data and an apparatus 
therefor. 
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Summary of the Invention 
In accordance with the principles of the invention, an embodiment of a method of 
determining a time delay for a round-trip transmission of data comprises receiving a first data 
packet comprising a first IP source address, a first IP destination address, a first TCP source port, 
5 a first TCP destination port, and a first time stamp indicating a first time when the first data 
packet was transmitted. The method continues by inserting the first IP destination address as a 
second EP source address in a second data packet and by inserting the first IP source address as a 
second IP destination address in the second data packet. Next, the method proceeds by inserting 
in the first TCP destination port as a second TCP source port in the second data packet and by 
HO inserting the first TCP source port as a second TCP destination port in the second data packet. 
j 3 Then, the method continues by inserting the first time stamp as a second time stamp in the 
: second data packet and by transmitting the second data packet. 

m Further, in accordance with the principles of the invention, an embodiment of an 

O electronic apparatus for determining a time delay for a round-trip transmission of data comprises 
45 a data reception portion, an input memory portion coupled to the data reception portion, a data 
validity portion coupled to the data reception portion, and a first memory and data transfer 
management portion coupled to the input memory portion and the data validity portion. The 
electronic apparatus further comprises a second memory and data transfer management portion 
coupled to the first memory and data transfer management portion, an output memory portion 
20 coupled to the input memory portion and the second memory and data transfer management 
portion, and a data pattern management portion coupled to the second memory and data transfer 
management portion. The electronic apparatus additionally comprises a header format portion 

2 

PX01DOCS/244625.02 



1 

1 

coupled to the output memory portion and a data transmission portion coupled to the header 
format portion and the data pattern management portion. 

Brief Description of the Drawing 
5 The invention will be better understood from a reading of the following detailed 

description, taken in conjunction with the accompanying drawing figures in which: 

FIG. 1 illustrates a block diagram of an electronic apparatus for determining a time delay 
of a round-trip transmission of data in accordance with an embodiment of the invention; 
■3 FIG. 2 illustrates a flow chart for a method of determining a time delay for a round-trip 

fl 0 transmission of data in accordance with an embodiment of the invention; and 
{ 7z FIGs. 3 through 6 illustrate flow charts of detailed portions of the method of FIG. 2 in 

accordance with an embodiment of the invention. 
S For simplicity and clarity of illustration, the same reference numerals in different figures 

S denote the same elements, and descriptions and details of well-known features and techniques are 
45 omitted to avoid unnecessarily obscuring the invention. 

Furthermore, the terms first, second, third, fourth, and the like in the description and in 
the claims, if any, are used for distinguishing between similar elements and not necessarily for 
describing a sequential or chronological order. However, it is understood that the embodiments 
of the invention described herein are capable of operation in other sequences than described or 
20 illustrated herein. It is further understood that the terms so used are interchangeable under 
appropriate circumstances. 
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Detailed Description 

FIG. 1 illustrates a block diagram of an electronic device or apparatus 100 for 
determining a time delay of a round-trip transmission of data. Electronic apparatus 100 
comprises an incoming data portion and an outgoing data portion. The incoming data portion 
5 includes a data reception portion 1 10, an input memory portion 115, a data validity portion 120, 
and, a first memory and data transfer management portion 125. Input memory portion 115 and 
data validity portion 120 are both coupled to data reception portion 110. Memory and data 
transfer management portion 125 is coupled to both of input memory portion 115 and data 
; jg validity portion 120. 

120 The outgoing data portion of electronic apparatus 100 comprises a second memory and 

y data transfer management portion 150, an output memory portion 155, a data pattern 
management portion 160, a header format portion 165, and a data transmission portion 170. 
m Memory and data transfer management portion 150 is coupled to memory and data transfer 
0 management portion 125. Output memory portion 155 is coupled to both of input memory 
4 5 portion 115 and memory and data transfer management portion 150. Data pattern management 
portion 160 is coupled to memory and data transfer management portion 150 and data 
transmission portion 170. Header format portion 165 is coupled to output memory portion 155, 
and data transmission portion 170 is coupled to header format portion 165. 

In the preferred embodiment, the incoming and outgoing data portions of electronic 
20 apparatus 100 are formed within a single field-programmable gate array (FPGA), as indicated by 
a dashed line 105. For example, memory portions 115, 155, memory and data transfer 
management portions 125, 150, data validity portion 120, data reception portion 110, data 
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transmission portion 170, header format portion 165, and data pattern management portion 160 

can be located within the single FPGA. 

Electronic apparatus 100 further comprises a data pattern memory portion 190 coupling 

data pattern management portion 160 to data transmission portion 170. In the preferred 
5 embodiment, data pattern memory portion 190 is not included in the FPGA. Instead, data pattern 

memory portion 190 is a preferably a separate dynamic random access memory (DRAM). 

As a brief overview of the operation of electronic apparatus 100, data reception portion 

110 receives an incoming data packet or frame, and data validity portion 120 validates the 
']% incoming data packet. Input memory portion 115 receives a portion of the incoming data packet 
AO from data reception portion 110, and input memory portion 115 stores the portion of the 
j 3 incoming data packet. The portion of the incoming data packet comprises, among other items, an 
w ' Internet Protocol (IP) source address, an IP destination address, a Transport Control Protocol 
:S (TCP) source port, a TCP destination port, and a time stamp. Memory and data transfer 
sfi management portions 125, 150 interact or cooperate to manage a transfer of the stored portions 
r -15 of the incoming data packet from input memory portion 115 to output memory portion 155. 

Output memory portion 155 receives the portion of the incoming data packet from input memory 

portion 115, and output memory portion 155 stores the portion of the incoming data packet. 

Header format portion 165 takes the portion of the incoming data packet and inserts it into an 

outgoing data packet transmitted out of electronic apparatus 100 through data transmission 
20 portion 170. Data pattern management portion 160 manages an insertion of a data pattern from 

data pattern memory portion 190 into the outgoing data packet from data transmission portion 

170. The operation of electronic apparatus 100 is described in more detail with reference to 

FIGs. 2 through 6. 
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FIG. 2 illustrates a flowchart for a method 200 of determining a time delay for a round- 
trip transmission data. A first electronic device or apparatus transmits a first data packet at a first 
time where the first electronic apparatus has a first IP source address and a first TCP source port. 
In the preferred embodiment, the first data packet comprises the first IP source address, a first IP 
5 destination address, a first IP checksum, the first TCP source port, a first TCP destination port, a 
first set of six TCP flags, a first TCP checksum, a first data pattern, a first time stamp indicating 
the first time when the first data packet was transmitted from the first electronic apparatus, and a 
first Checklist Redundancy Check (CRC) checksum. A second electronic device or apparatus, 
% such as electronic apparatus 100 of FIG. 1 waits for the first data packet. The second electronic 
:H0 apparatus has the first IP destination address and the first TCP destination port. 
Q At a step 205 of method 200 in FIG. 2, the second electronic apparatus begins to receive 

^ the first data packet transmitted from the first electronic apparatus. Upon beginning to receive 
:S the first data packet, the second electronic apparatus checks a status of a first memory portion 
;y within the second electronic apparatus. As an example, referring back to FIG. 1, as data 
Q5 reception portion 110 begins to receive the first data packet, memory and data transfer 
management portion 125 checks the status of input memory portion 115. If the status of input 
memory portion 1 15 is full, then method 200 (FIG. 2) terminates or starts over by waiting for a 
new data packet and begins receiving the new data packet at step 205 (FIG. 2). However, if the 
status of input memory portion 1 15 is empty or if input memory portion 115 has enough empty 
20 memory to store desired portions of the first data packet, then data reception portion 110 begins 
identifying different portions of the first data packet while receiving the first data packet. In the 
preferred embodiment, input memory portion 1 15 is large enough to store the desired portions of 

two data packets. Electronic apparatus 100 stores the identified portions of the first data packet 
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within input memory portion 115 while receiving the first data packet. Data validity portion 120 
validates the different portions of the first data packet while electronic apparatus 100 receives the 
different portions of the first data packet. 

Returning to FIG. 2, step 205 of method 200 also begins the calculation of a CRC 
checksum for the first data packet. This calculation begins with the first byte of data of the first 
data packet and preferably starts upon receiving the first byte of data of the first data packet. 
Next, steps 210, 215, and 220 of method 200 briefly describe the identifying, storing, and 
validating steps described in the previous paragraph. At step 210, the second electronic 
apparatus identifies, stores, and validates portions of an IP header of the first data packet, and at a 
step 215, the second electronic apparatus identifies, stores, and validates portions of a TCP 
header of the first data packet. At step 220, the second electronic apparatus identifies and stores 
the time stamp of the first data packet. Steps 210 and 215 are described in more detailed 
hereinafter with respect to FIGs. 3 and 4, respectively. 

At a step 225 of method 200, the second electronic apparatus stops receiving the first data 
packet. Then, at a step 230, the second electronic apparatus validates the entire first data packet 
based on a CRC checksum match. As an example, the second electronic apparatus can perform 
step 230 by comparing the calculated and received CRC checksums. If the calculated and 
received CRC checksums are not equal to each other, then method 200 terminates or starts over 
by waiting for a new data packet and begins receiving the new data packet at step 205. However, 
if the calculated and received CRC checksums are equal to each other, then method 200 
continues such that the second electronic apparatus sets or changes the status of the first memory 
portion storing the portions of the first data packet from empty to full. 



PX01 DOCS/244625.02 



7 



Then, the second electronic apparatus checks a status of a second memory portion within 
the second electronic apparatus. If the status of the second memory portion is full, then the 
second electronic apparatus waits until at least a portion of the second memory potion is free, is 
empty, or otherwise becomes available. This portion of the second memory portion needs to be 
5 large enough to store the portions of the first data packet currently stored in the first memory 
portion. After the portion of the second memory becomes available, the second electronic 
apparatus transfers the stored portions of the first data packet from the first memory portion to 
the second memory portion. Then, the second electronic apparatus sets or changes the status of 
!S the second memory portion from empty to full, and the second electronic apparatus also sets or 
~3l0 changes the status of the first memory portion from full to empty. As an example, referring back 
j 3 to FIG. 1, memory and data transfer management portions 125, 150 cooperate or interact to 
u transfer the stored portions of the first data packet from input memory portion 115 to output 
m memory portion 155. In the preferred embodiment, steps 210, 215, and 220 in FIG. 2 are 
0 performed in real-time while simultaneously receiving the first data packet. 
Q5 Returning to FIG. 2, method 200 continues at a step 235 where the second electronic 

apparatus begins transmitting a second data packet back to the first electronic apparatus. Step 
235 of method 200 also begins the calculation of a CRC checksum for the second data packet. 
This calculation begins with the first byte of data of the second data packet. At a step 240, the 
second electronic apparatus inserts the stored portions of the IP header of the first data packet 
20 into an IP header of the second data packet, and at a step 245, the second electronic apparatus 
inserts the stored portions of the TCP header of the first data packet into a TCP header of the 
second data packet. As an example, header format portion 165 (FIG. 1), output memory portion 
155 (FIG. 1), and data transmission portion 170 (FIG. 1) can perform steps 240 and 245 in FIG. 
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2. Steps 240 and 245 are described in more detailed hereinafter with respect to FIGs. 5 and 6, 
respectively. 

Returning back to FIG. 2, at a step 250 of method 200, the second electronic apparatus 
sends or transmits a second data pattern as part of the second data packet. The second data 
5 pattern of the second data packet can be the same as or different from the first data pattern in the 
first data packet. As an example, data pattern management portion 160 (FIG. 1), data pattern 
memory portion 190 (FIG. 1), and data transmission portion 170 (FIG. 1) can perform step 250. 

Subsequently, at a step 255 of method 200, the second electronic apparatus inserts the 
first time stamp of the first data packet stored in the second memory portion as a second time 
AO stamp in the second data packet. Next, at a step 260, the second electronic apparatus inserts a 
j H validity check for the second data packet into the second data packet. As an example, the 
u validity check is a second CRC checksum that is different from the first CRC checksum of the 
m first data packet. In the preferred embodiment, header format portion 165 (FIG. 1), output 
O memory portion 155 (FIG. 1), and data transmission portion 170 (FIG. 1) perform steps 255 and 
45 260. Subsequently, at a step 265 of method 200, the second electronic apparatus stops 
transmitting the second data packet. In the preferred embodiment, steps 240, 245, 250, 255, and 
260 are performed in real-time while simultaneously transmitting the second data packet. 

Next, the first electronic apparatus receives the second data packet at a second time. This 
second time occurs after the first time at which the first electronic apparatus originally 
20 transmitted the first data packet to the second electronic apparatus. The first electronic apparatus 
determines the time delay for the round-trip transmission of data from the first electronic 
apparatus to the second electronic apparatus and back to the first electronic apparatus by 
subtracting the time indicated by the second time stamp in the second data packet from the 
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second time. As indicated earlier at step 255, the second time stamp in the second data packet 
contains the first time at which the first electronic apparatus transmitted the first data packet. 

FIG. 3 illustrates a flowchart of substeps within step 210 of FIG. 2. At a step 310 in FIG. 
3, the second electronic apparatus identifies a beginning of the IP header in the first data packet, 
5 and at a step 320, the second electronic apparatus begins calculating an IP checksum for the first 
data packet. At a step 330, the second electronic apparatus identifies an IP source address within 
the IP header of the first data packet, and at a step 340, the second electronic apparatus stores the 
first IP source address. Then, at a step 350, the second electronic apparatus identifies an IP 
!n destination address in the IP header of the first data packet, and at a step 360, the second 
Ho electronic apparatus stores the IP destination address. Next, at a step 370, the second electronic 
3 apparatus identifies an end of the IP header, and, at a step 380, the second electronic apparatus 
Q validates the IP header data of the first data packet based on an IP checksum match. 
!J To perform step 380, the second electronic apparatus finishes calculating the IP 

=5 checksum for the first data packet and compares the calculated IP checksum to the received IP 
215 checksum of the first data packet. If the calculated and received IP checksums are equal to each 
other, then the IP checksum of the first data packet is valid, and method 200 (FIG. 2) continues 
with step 215 (FIG. 2). However, if the calculated and received IP checksums are not equal to 
each other, then method 200 (FIG. 2) terminates or starts over, and the second electronic 
apparatus waits for another data packet and begins receiving the other data packet at step 205 
20 (FIG. 2). In the preferred embodiment, steps 310, 320, 330, 340, 350, 360, 370, and 380 are 
performed in real-time while simultaneously receiving the first data packet. Also in the preferred 
embodiment, the second electronic apparatus identifies and stores the IP source and destination 
addresses before validating the IP header data. 
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FIG. 4 illustrates a flowchart of the substeps within step 215 of FIG. 2. At a step 410 of 
FIG. 4, the second electronic apparatus identifies a beginning of the TCP header in the first data 
packet. Then, at a step 415, the second electronic apparatus begins to calculate a TCP checksum 
for the first data packet. Next, at a step 420, the second electronic apparatus identifies a TCP 
5 source port in the TCP header of the first data packet, and a step 430, the second electronic 
apparatus stores the TCP source port. At a step 440, the second electronic apparatus identifies a 
TCP destination port in the TCP header of the first data packet, and at a step 450, the second 
electronic apparatus stores the TCP destination port. Then, at a step 460, the second electronic 
i« apparatus identifies the TCP flags in the TCP header of the first data packet, and at a step 470, 
flO the second electronic apparatus stores at least a portion of the TCP flags. In the preferred 
□ embodiment, the second electronic apparatus receives six TCP flags in the first data packet, but 
u stores only two of the six TCP flags. In particular, the second electronic apparatus stores the 
m TCP flags identified as a final (FIN) flag and a synchronous (SYN) flag. Next, at a step 480, the 
o second electronic apparatus identifies an end of the TCP data, and at a step 490, the second 
45 electronic apparatus validates the TCP data, including the TCP header, in the first data packet 
based on a TCP checksum match. 

As an example, the second electronic apparatus can perform step 490 by comparing the 
calculated and received TCP checksums. If the calculated and received TCP checksums are 
equal to each other, then method 200 (FIG. 2) continues with step 220 (FIG. 2). However, if the 
20 calculated and received checksums are not equal to each other, then method 200 (FIG. 2) 
terminates or starts over, and the second electronic apparatus waits to receive another data packet 
and begins receiving the new data packet at step 205 (FIG. 2). Also in the preferred 
embodiment, the second electronic apparatus performs steps 410, 420, 430, 440, 450, 460, 470, 
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480, and 490 in real-time while simultaneously receiving the first data packet. Furthermore, the 
second electronic apparatus preferably identifies and stores the TCP source and destination ports 
and the TCP flags before validating the TCP data. 

FIG. 5 illustrates a flowchart of the substeps in step 240 of FIG. 2. At a step 510 of FIG. 
5 6, the second electronic apparatus counts an IP header offset, and at a step 520, the second 
electronic apparatus calculates a second IP checksum for the second data packet. Step 520 can 
be performed at this time because the portions of the IP header used to calculate IP checksum are 
already known and stored in the second memory portion. Next, at a step 530, the second 
:?5 electronic apparatus adds an IP checksum offset to the IP header offset, and at a step 540, the 
AO second electronic apparatus inserts the calculated IP checksum into the second data packet. 
Q Next, at a step 550, the second electronic apparatus adds an IP source address offset to the 
u previous offset sum, and then the second electronic apparatus uses the first IP destination address 
m of the first data packet stored in the second memory portion. In particular, at a step 560, the 
o second electronic apparatus inserts the first IP destination address as a second IP source address 
45 in the second data packet. 

Then, at a step 570, the second electronic apparatus adds an IP destination address offset 
to the previous offset sum, and then the second electronic apparatus uses the first IP source 
address of the first data packet stored in the second memory portion. In particular, at a step 580, 
the second electronic apparatus inserts the first IP source address as a second IP destination 
20 address in the second data packet. In the preferred embodiment, the second electronic apparatus 
performs steps 520, 530, and 540 before steps 550, 560, 570, and 580. Also in the preferred 
embodiment, the second electronic apparatus performs steps 510, 520, 530, 540, 550, 560, 570, 

and 580 in real-time while simultaneously transmitting the second data packet. 
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FIG. 6 illustrates a flowchart of the substeps of step 245 in FIG. 2. At a step 610 in FIG. 
6, the second electronic apparatus counts a TCP header offset, and at a step 620, the second 
electronic apparatus adds a TCP source port offset to the TCP header offset. Then, the second 
electronic apparatus uses the first TCP destination port of the first data packet stored in the 
5 second memory portion. In particular, at a step 630, the second electronic apparatus inserts the 
first TCP destination port as a second TCP source port in the second data packet. Next, at a step 
640, the second electronic apparatus adds a TCP destination port offset to the previous offset 
sum, and then the second electronic apparatus uses the first TCP source port of the first data 
S packet stored in the second memory portion. In particular, at a step 650, the second electronic 
■'do apparatus inserts the first TCP source port as a second TCP destination port in the second data 
y packet. 

^ Subsequently, at a step 660, the second electronic apparatus adds a TCP flag offset to the 

m previous offset sum, and then the second electronic apparatus uses the two TCP flags of the first 
0 data packet stored in the second memory portion. In particular, at a step 670, the second 
j 45 electronic apparatus inserts the FIN flag and the SYN flag as a portion of the second TCP flags 
into the second data packet. The second electronic apparatus also inserts four other TCP flags, 
for a total of six TCP flags, into the second data packet. In particular, the second electronic 
apparatus inserts a TCP flag identified as an acknowledgment (ACK) flag where the ACK flag 
has a value of one. The second electronic apparatus also inserts three other TCP flags, each 
20 having a value of zero. 

Then, at a step 680, the second electronic apparatus adds a TCP checksum offset to the 
previous offset sum, and at a step 690, the second electronic apparatus calculates and inserts the 
second TCP checksum into the second data packet. In the preferred embodiment, the second 
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electronic apparatus component begins and finishes calculating the second TCP checksum after 
step 680. Also in the preferred embodiment, the second electronic apparatus performs steps 610, 
620, 630, 640, 650, 660, and 670 before steps 680 and 690. Furthermore, the second electronic 
apparatus preferably performs steps 610, 620, 630, 640, 650, 660, 670, 680, and 690 in real-time 
while simultaneously transmitting the second data packet. 

Therefore, an improved method of determining a time delay for the round-trip 
transmission of data and an apparatus therefor are provided to overcome the disadvantages of the 
prior art. The method and apparatus enable the detection of an increase or decrease in the time 
delay for the round-trip transmission of data across a computer network. 

Although the invention has been described with reference to specific embodiments, it will 
be understood by those skilled in the art that various changes may be made without departing 
from the spirit or scope of the invention. For instance, the numerous details set forth herein such 
as, for example, the specific sequence of steps are provided to facilitate the understanding of the 
invention and are not provided to limit the scope of the invention. Furthermore, the method 
described herein is not limited to the round-trip transmission of data between two electronic 
devices. Instead, the method can be modified and applied to the round-trip or non-round-trip 
transmission of data between three or more electronic devices. Accordingly, the disclosure of 
embodiments of the invention is intended to be illustrative of the scope of the invention and is 
not intended to be limiting. It is intended that the scope of the invention shall be limited only to 
the extent required by the appended claims. 
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CLAIMS 



1 LA method of determining a time delay for a round-trip transmission of data 

2 comprising: 

3 receiving a first data packet comprising a first IP source address, a first IP destination 

4 address, a first TCP source port, a first TCP destination port, and a first time stamp indicating a 

5 first time when the first data packet was transmitted; 

6 inserting the first IP destination address as a second IP source address in a second data 
; g7 packet; 

0 8 inserting the first IP source address as a second IP destination address in the second data 

nf9 packet; 

4o inserting the first TCP destination port as a second TCP source port in the second data 

;|l 1 packet; 

fl2 inserting the first TCP source port as a second TCP destination port in the second data 

Q3 packet; 

14 inserting the first time stamp as a second time stamp in the second data packet; and 

1 5 transmitting the second data packet. 

16 2. The method of claim 1 further comprising: 

1 7 transmitting the first data packet at the first time; 

1 8 receiving the second data packet at a second time; and 

19 determining a difference between the first time in the second time stamp and the second 

20 time to establish the time delay for the round-trip transmission of data. 
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1 3 . The method of claim 1 further comprising : 

2 validating the first IP destination address while receiving the first data packet, before 

3 inserting the first IP destination address, before inserting the first IP source address, before 

4 inserting the first TCP destination port, before inserting the first TCP source port, and before 

5 transmitting the second data packet; and 

6 validating the first TCP destination port while receiving the first data packet, before 

7 inserting the first IP destination address, before inserting the first IP source address, before 
inserting the first TCP destination port, before inserting the first TCP source port, and before 

= 0 9 transmitting the second data packet. 



: i0 4. The method of claim 1 wherein: 

if| i inserting the first IP destination address occurs while transmitting the second data packet; 

^Q2 and 

( 43 inserting the first IP source address occurs while transmitting the second data packet. 

14 5 . The method of claim 1 wherein: 

15 inserting the first TCP destination port occurs while transmitting the second data packet; 

16 and 

1 7 inserting the first TCP source port occurs while transmitting the second data packet. 
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6. The method of claim 1 wherein: 

inserting the first time stamp occurs while transmitting the second data packet. 



3 7. The method of claim 1 further comprising: 

4 providing the first data packet to further comprise a first IP checksum, a first TCP 

5 checksum, and a first CRC checksum; 

6 validating the first IP checksum while receiving the first data packet; 

7 validating the first TCP checksum while receiving the first data packet; and 
3 a 8 validating the first CRC checksum. 

■39 8. The method of claim 7 further comprising: 

:s i0 storing the first IP source address and the first IP destination address before validating the 

iff 1 first IP checksum; and 

a 2 storing the first TCP source port and the first TCP destination port after validating the 

: =43 first IP checksum and before validating the first TCP checksum. 

14 9. The method of claim 7 wherein: 

15 validating the first TCP checksum occurs after validating the first IP checksum and 

1 6 before validating the first CRC checksum. 

17 10. The method of claim 7 wherein: 

18 validating the first CRC checksum occurs after receiving the first data packet. 
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1 1 L The method of claim 7 further comprising: 

2 determining a second IP checksum for the second data packet; 

3 inserting the second IP checksum into the second data packet while transmitting the 

4 second data packet; 

5 determining a second TCP checksum for the second data packet; and 

6 inserting the second TCP checksum into the second data packet while transmitting the 

7 second data packet. 

= o 8 12. The method of claim 1 1 wherein: 

□ 9 inserting the first IP destination address occurs while transmitting the second data packet; 

40 inserting the first IP source address occurs while transmitting the second data packet; 

! J[ 1 inserting the first TCP destination port occurs while transmitting the second data packet; 

: A 2 inserting the first TCP source port occurs while transmitting the second data packet; and 

Q 3 inserting the first time stamp occurs while transmitting the second data packet. 

14 13. The method of claim 1 1 wherein: 

15 inserting the first IP destination address occurs after inserting the second IP checksum; 

16 inserting the first IP source address occurs after inserting the first IP destination address; 

17 inserting the first TCP destination port occurs after inserting the first IP source address; 

18 and 

19 inserting the first TCP source port occurs after inserting the first TCP destination port and 

20 before inserting the second TCP checksum. 
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1 14. The method of claim 1 further comprising: 

2 providing the first data packet to further comprise a first data pattern; and 

3 inserting a second data pattern into the second data packet. 

4 15. The method of claim 1 4 wherein: 

5 inserting the second data pattern occurs while transmitting the second data packet. 

^6 16. The method of claim 1 further comprising: 

r-i 7 providing the first data packet to further comprise a first TCP flag; and 

□ 8 inserting the first TCP flag as a second TCP flag into the second data packet. 

^9 17. The method of claim 1 6 further comprising: 

rtO validating the first TCP flag while receiving the first data packet, before inserting the first 



3 1 IP destination address, before inserting the first IP source address, before inserting the first TCP 

12 destination port, before inserting the first TCP source port, before transmitting the second data 

13 packet, and before inserting the first TCP flag. 

14 18. The method of claim 1 6 wherein: 

1 5 inserting the second TCP flag occurs while transmitting the second data packet. 
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1 19. The method of claim 1 further comprising: 

2 providing the first data packet to further comprise two TCP flags; 

3 inserting the two TCP flags into the second data packet; 

4 inserting an additional TCP flag into the second data packet, the additional TCP flag 

5 having a value of one; and 

6 inserting three additional TCP flags into the second data packet, the three additional TCP 

7 flags each having a value of zero. 

8 20. The method of claim 1 further comprising: 

9 providing the first data packet to further comprising six TCP flags; 
Q0 inserting two of the six TCP flags into the second data packet; 

H 1 inserting an additional TCP flag into the second data packet, the additional TCP flag 

lit 2 having a value of one; and 

:l3 inserting three additional TCP flags into the second data packet, the three additional TCP 

; 3 4 flags each having a value of zero . 

15 21. The method of claim 20 further comprising: 

16 providing a FIN flag and a SYN flag for the two of the six TCP flags; and 

1 7 providing an ACK flag for the additional TCP flag. 

1 8 22. The method of claim 1 further comprising: 

19 providing the first data packet to further comprise a first IP checksum, first TCP flags, a 

20 first TCP checksum, and a first CRC checksum; 
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1 validating the first IP checksum while receiving the first data packet; 

2 validating the first TCP checksum while receiving the first data packet; 

3 validating the first CRC checksum after receiving the first data packet; 

4 determining a second IP checksum for the second data packet; 

5 inserting and the second IP checksum into the second data packet while transmitting the 

6 second data packet; 

7 inserting the first TCP flags as second TCP flags into the second data packet while 

8 transmitting the second data packet; 

^9 determining a second TCP checksum for the second data packet; 

=^0 inserting the second TCP checksum into the second data packet while transmitting the 

=3 1 second data packet; 

42 determining a second CRC checksum for the second data packet; and 

3(3 inserting the second CRC checksum into the second data packet while transmitting the 

: fj 4 second data packet. 

15 23 . The method of claim 22 wherein: 

16 inserting the first IP destination address occurs while transmitting the second data packet; 

17 inserting the first EP source address occurs while transmitting the second data packet; 

1 8 inserting the first TCP destination port occurs while transmitting the second data packet; 

19 inserting the first TCP source port occurs while transmitting the second data packet; and 

20 inserting the first time stamp occurs while transmitting the second data packet. 



21 

PX01DOCS/244625.02 



1 24. The method of claim 23 wherein: 

2 inserting the first IP destination address occurs after inserting the second IP checksum; 

3 inserting the first IP source address occurs after inserting the first IP destination address; 

4 inserting the first TCP destination port occurs after inserting the first IP source address; 

5 inserting the first TCP source port occurs after inserting the first TCP destination port; 

6 inserting the first TCP flags occurs after inserting the first TCP source port; 

7 inserting the second TCP checksum occurs after inserting the first TCP flags; 

8 inserting the first time stamp occur after inserting the second TCP checksum; and 
:? 9 inserting the second CRC checksum occurs after inserting the first time stamp. 

! 3 0 25 . The method of claim 24 further comprising: 

[ 4 1 providing the first data packet to further comprise a first data pattern; and 

!3(2 inserting a second data pattern into the second data packet while transmitting the second 

; 33 data packet. 

14 26. The method of claim 25 further comprising: 

15 transmitting the first data packet at the first time from a first electronic apparatus having 

16 the first IP source address and the first TCP source port; 

17 receiving the second data packet at a second time and at the first electronic apparatus 

18 having the second IP destination address and the second TCP destination port; and 

19 subtracting the first time in the second time stamp from the second time to determine the 

20 time delay for the round-trip transmission of data, 
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1 wherein: 

2 receiving the first data packet further comprises receiving the first data packet at a 

3 second electronic apparatus having the first IP destination address and the first TCP destination 

4 port; and 

5 transmitting the second data packet further comprises transmitting the second data 

6 packet from the second electronic apparatus having the second EP source address and the second 

7 TCP source port. 

^ 8 27. The method of claim 22 wherein: 

!>J9 inserting the first IP destination address occurs after inserting the second IP checksum; 

30 inserting the first IP source address occurs after inserting the first IP destination address; 

Q 1 inserting the first TCP destination port occurs after inserting the first IP source address; 

y 2 inserting the first TCP source port occurs after inserting the first TCP destination port; 

J 3 inserting the first TCP flags occurs after inserting the first TCP source port; 

:34 inserting the second TCP checksum occurs after inserting the first TCP flags; 

15 inserting the first time stamp occur after inserting the second TCP checksum; and 

16 inserting the second CRC checksum occurs after inserting the first time stamp. 

17 28. The method of claim 22 further comprising: 

18 providing the first data packet to further comprise a first data pattern; and 

19 inserting a second data pattern into the second data packet while transmitting the second 

20 data packet. 
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1 29. The method of claim 22 further comprising: 

2 transmitting the first data packet at the first time from a first electronic apparatus having 

3 the first IP source address and the first TCP source port; 

4 receiving the second data packet at a second time and at the first electronic apparatus 

5 having the second IP destination address and the second TCP destination port; and 

6 subtracting the first time in the second time stamp from the second time to determine the 

7 time delay for the round-trip transmission of data, 
"f 8 wherein: 

:H9 receiving the first data packet further comprises receiving the first data packet at a 

□0 second electronic apparatus having the first IP destination address and the first TCP destination 

4l port; and 

:32 transmitting the second data packet further comprises transmitting the second data 

:j§3 packet from the second electronic apparatus having the second IP source address and the second 

□4 TCP source port. 

15 30. The method of claim 1 further comprising: 

1 6 waiting for the first data packet; 

1 7 checking a status of a first memory portion; 

18 storing a portion of the first data packet if the first memory portion is available, the 

19 portion of the first memory portion comprising the first IP source address, the first IP destination 

20 address, the first TCP source port, and the first TCP destination port; 
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1 checking a validity of the first data packet; 

2 setting the status of the first memory portion to full if the first data packet is valid; 

3 checking a status of a second memory portion; 

4 transferring the portion of the first data packet from the first memory portion to the 

5 second memory portion if the second memory portion is available and if the first data packet is 

6 valid; 

7 setting the status of the second memory portion to full; and 

8 setting the status of the first memory portion to empty. 

/j^9 31. An electronic apparatus for determining a time delay for a round-trip transmission 

fJO of data comprising: 

' 3 1 a data reception portion; 

; j2 an input memory portion coupled to the data reception portion; 

13 a data validity portion coupled to the data reception portion; 

i J4 a first memory and data transfer management portion coupled to the input memory 

1 5 portion and the data validity portion; 

16 a second memory and data transfer management portion coupled to the first memory and 

1 7 data transfer management portion; 

18 an output memory portion coupled to the input memory portion and the second memory 

1 9 and data transfer management portion; 

20 a data pattern management portion coupled to the second memory and data transfer 

2 1 management portion; 
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1 a header format portion coupled to the output memory portion; and 

2 a data transmission portion coupled to the header format portion and the data pattern 

3 management portion. 



4 32. The electronic apparatus of claim 3 1 further comprising: 

5 an incoming data portion comprising: 

6 the data reception portion; 

7 the input memory portion; 
[%8 the data validity portion; and 

3 K9 the first memory and data transfer management portion; and 

□0 an outgoing data portion comprising: 

1 1 the second memory and data transfer management portion; 

'32 the output memory portion; 

T !§3 the data pattern management portion; 

34 the header format portion; and 

1 5 the data transmission portion. 



16 33. The electronic apparatus of claim 3 1 wherein: 

1 7 the input memory portion stores a portion of an incoming data packet; 

18 the first and second memory and data transfer management portions manage a transfer of 

19 the portion of the incoming data packet from the input memory portion to the output memory 

20 portion; 
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1 the data validity portion validates the incoming data packet; 

2 the output memory portion receives the portion of the incoming data packet from the 

3 input memory portion; 

4 the data pattern management portion manages an insertion of a data pattern into an 

5 outgoing data packet; and 

6 a header format portion inserts an IP source address, an IP destination address, a TCP 

7 source port, a TCP destination port, TCP flags, and a time stamp into the outgoing data packet. 

^8 34, The electronic apparatus of claim 31 wherein: 

^9 the input memory portion, the output memory portion, the first and second memory and 

! :)0 data transfer management portions, the data validity portion, the data reception portion, the data 

31 transmission portion, the header format portion, and the data pattern management portion are 

;i2 located within a field-programmable gate array. 

i3S 35. The electronic apparatus of claim 3 1 further comprising: 

14 a data pattern memory portion coupling the data pattern management portion to the data 

1 5 transmission portion. 

16 36. The electronic apparatus of claim 35 wherein: 

17 the data pattern memory portion is a dynamic random access memory. 
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1 37. The electronic apparatus of claim 36 wherein: 

2 the input memory portion, the output memory portion, the first and second memory and 

3 data transfer management portions, the data validity portion, the data reception portion, the data 

4 transmission portion, the header format portion, and the data pattern management portion are 

5 located within a field-programmable gate array. 
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METHOD OF DETERMINING TIME DELAY 
FOR ROUND-TRIP TRANSMISSION OF DATA AND 
ELECTRONIC APPARATUS THEREFOR 

Abstract of the Disclosure 

A method of determining a time delay for a round-trip transmission of data includes 
receiving a first data packet having a first IP source address, a first IP destination address, a first 
TCP source port, a first TCP destination port, and a first time stamp indicating a first time when 
the first data packet was transmitted. The method continues by inserting the first IP destination 
address as a second IP source address in a second data packet and by inserting the first IP source 
address as a second IP destination address in the second data packet. Next, the method proceeds 
by inserting the first TCP destination port as a second TCP source port in the second data packet 
and by inserting the first TCP source port as a second TCP destination port in the second data 
packet. Then, the method continues by inserting the first time stamp as a second time stamp in 
the second data packet and by transmitting the second data packet. 

An electronic apparatus for determining a time delay for a round-trip transmission of data 
includes a data reception portion, an input memory portion coupled to the data reception portion, 
a data validity portion coupled to the data reception portion, and a first memory and data transfer 
management portion coupled to the input memory portion and the data validity portion. The 
electronic apparatus further includes a second memory and data transfer management portion 
coupled to the first memory and data transfer management portion, an output memory portion 
coupled to the input memory portion and the second memory and data transfer management 
portion, and a data pattern management portion coupled to the second memory and data transfer 
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management portion. The electronic apparatus additionally includes a header format portion 
coupled to the output memory portion and a data transmission portion coupled to the header 
format portion and the data pattern management portion. 
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In accordance with 37 C.F.R. § 3.73(b), a copy of the Assignment is attached hereto. A copy of the 
Assignment has also been filed or is being filed contemporaneously herewith for recordation with 
the Assignment Branch. 

DOA Communications hereby revokes all previous powers of attorney and appoints John T. 
Jones, Reg. No. 45,550; Susan Stone Rosenfield, Reg. No. 36,287, and George C. Chen, Reg. No. 
39,935 of the firm of Bryan Cave LLP, Two North Central Avenue, Suite 2200, Phoenix, Arizona, 
85004, telephone (602) 364-7000, facsimile (602) 364-7000, as its attorneys with full powers of 
substitution, revocation and association, to transact all business in the United States Patent and 
Trademark Office in connection with the above-identified patent application. 

Please direct all correspondence regarding this patent application to George C. Chen, Bryan 
Cave LLP, Two North Central Avenue, Suite 2200, Phoenix, Arizona 85004, phone (602) 364- 
7000. 



In re Application of: 



POWER OF ATTORNEY 



IXIA COMMUNICATIONS 



Dated: 




256965 



